草庐IT

php - 为什么在我们有 json_encode 时使用 CJSON 编码

全部标签

ruby - 为什么 bundler 使用多个 gem 位置?

这发生在Puppet'sbundle。Gemfilespecifiesgem"puppet",:path=>File.dirname(__FILE__),:require=>false但是我安装在$GEM_HOME中的一个gem最终出现在$:中。$bundleexecruby-e'puts$:'.../home/puppy/puppet-git-clone/lib.../usr/lib/ruby/vendor_ruby.../home/puppy/gems/gems/puppet-3.7.5/lib...这本身并不是问题,但显然Ruby将加载Puppet3.7.5而不是我从git存储库

ruby - "base.send :include, InstanceMethods"---> 这是做什么的?

我正在查看一个模块X,它包含两个名为“InstanceMethods”和“ClassMethods”的模块。模块X中的最后一个定义是这样的:defself.included(base)base.send:include,InstanceMethodsbase.send:extend,ClassMethodsend这是做什么的? 最佳答案 included在一个模块被包含到另一个模块或类中时被调用。在这种情况下,它将尝试调用base的include方法来从InstanceMethods中获取模块方法、变量和常量添加到base然后将尝试

ruby - gemspec 文件中的 `files` 、 `executables` 、 `test_files` 和 `require_paths` 是什么?

我不清楚.gemspec文件中的某些规范在做什么。具体来说,spec.files=`gitls-files-z`.split("\x0")spec.executables=spec.files.grep(%r{^bin/}){|f|File.basename(f)}spec.test_files=spec.files.grep(%r{^(test|spec|features)/})spec.require_paths=["lib"]谁能解释一下这些与RubyGem的功能有何关系以及为什么需要它们? 最佳答案 executables:

ruby - 与 MRI 相比,mruby 的主要遗漏是什么?

我对mruby很感兴趣项目,但没有找到mruby与其他更完整的Ruby实现(最重要的是MRI)相比主要遗漏的总结。项目中的自述文件说mruby实现了ISOstandard的“一部分”对于Ruby,但没有详细说明省略了哪些功能。有没有人知道此类遗漏的列表,或者是否有足够熟悉实现的人来总结一下? 最佳答案 所以我没有仔细阅读源码,但是在构建了mruby并运行了一下解释器之后,我发现缺少以下内容(这绝不是一个完整的列表,我也不知道这些是否是故意遗漏或只是还没有写的东西):反引号评估字符串#scan(instance|module|clas

ruby - 为什么 Enumerable#detect 需要 Proc/lambda?

Enumerable#detect返回block评估为true的数组的第一个值。它有一个可选参数,需要响应call并在这种情况下被调用,返回它的值。所以,(1..10).detect(lambda{"none"}){|i|i==11}#=>"none"为什么我们需要lambda?为什么我们不直接传递默认值本身,因为(在我的测试中)lambda无论如何都不能有任何参数?像这样:(1..10).detect("none"){|i|i==11}#=>"none" 最佳答案 与Ruby中的所有事物一样,“最小意外原则”适用。当然,这并不是说

ruby - 在 ruby​​ 中使用字符串插值会发生什么?

我认为ruby​​只是调用方法to_s但我无法解释它是如何工作的:classFakedefto_sselfendend"#{Fake.new}"根据逻辑,由于无限递归,这应该将堆栈级别提升得太深。但它工作正常,似乎从对象调用#to_s。=>"#"但为什么呢?已添加:classFakedefto_sFake2.newendendclassFake2defto_s"Fake2#to_s"endend此代码在两种情况下的工作方式不同:puts"#{Fake.new}"=>"#"但是:putsFake.new.to_s=>"Fake2#to_s"我觉得不正常。有人可以建议在ruby​​解释器中

ruby-on-rails - ActiveRecord::Errors 的 Rails 3 替代品是什么?

ActiveRecord::Errors的Rails3替代品是什么?在Rails2.3.8中,这是一个对象:>>ActiveRecord::Errors=>ActiveRecord::Errors在Rails3.0.0rc中,你会得到一个NameError:>>ActiveRecord::ErrorsNameError:uninitializedconstantActiveRecord::Errorsfrom(irb):2我正在尝试制作wizardly生成器与Rails3一起工作。$railsgwizardly_scaffoldhome但失败了:/Library/Ruby/Gems/1

ruby - 在 ruby​​ 上,为什么 include 是私有(private)的而 extend 是公共(public)的?

在ruby上,为什么include是private,而Object#extend是public? 最佳答案 Object#extend必须是公开的,否则您将无法使用它。毕竟,它的目的是将模块混合到对象中,因此您通常会像obj.extend(Foo)那样调用它,这对于私有(private)方法是不可能的。Module#include通常只在模块体内使用,如下所示:classBarincludeFooend即它通常在没有接收者的情况下被调用,所以它不必公开。当然,它也必须是私有(private)的。我猜它之所以是私有(private)的

ruby - 模式匹配时 =~ 和 match() 有什么区别?

我正在使用Ruby1.9.3。我在玩一些模式,发现了一些有趣的东西:示例1:irb(main):001:0>/hay/=~'haystack'=>0irb(main):003:0>/st/=~'haystack'=>3示例2:irb(main):002:0>/hay/.match('haystack')=>#irb(main):004:0>/st/.match('haystack')=>#=~返回其第一个匹配项的第一个位置,而match返回模式。除此之外,=~和match()还有什么区别吗?执行时间差(根据@Casper)irb(main):005:0>quickbm(10000000

ruby - 当我不提供方法名称时,为什么 Ruby 会调用 `call` 方法?

给定以下模块:moduleFoodefself.call'foo'endend我当然希望以下内容有效:putsFoo.call#outputs"foo"但是,我没想到这会起作用:putsFoo.()#outputs"foo"显然,当方法名称被省略时,Ruby假定我想调用call方法。这在哪里记录,为什么它会这样? 最佳答案 Proc#call:Invokestheblock,settingtheblock’sparameterstothevaluesinparamsusingsomethingclosetomethodcalling